<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"
      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro"
>
<head>
    <meta charset="UTF-8">
    <title>权限管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="icon" href="/resources/favicon.ico">
    <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
    <link rel="stylesheet" href="/resources/css/public.css" media="all" />
    <link rel="stylesheet" href="/resources/layui_ext/dtree/dtree.css" media="all" />
    <link rel="stylesheet" href="/resources/layui_ext/dtree/font/dtreefont.css" media="all" />

</head>
<body class="childrenBody">
<!--查询条件开始-->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 30px;">
    <legend>查询条件</legend>
</fieldset>
<blockquote class="layui-elem-quote">
    <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">权限名称</label>
                <div class="layui-input-inline">
                    <input type="text" name="title"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">权限编码</label>
                <div class="layui-input-inline">
                    <input type="text" name="percode"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <button type="button" shiro:hasPermission="permission:view" class="layui-btn layui-btn-normal" lay-submit="" lay-filter="doSearch"><span class="layui-icon layui-icon-search"></span>查询</button>
                <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh"></span>重置</button>
            </div>
        </div>
    </form>
</blockquote>
<!--查询条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="permissionTable" lay-filter="permissionTable"></table>

    <div id="permissionToolBar" style="display: none">
        <button type="button" lay-event="add" shiro:hasPermission="permission:create" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-add-1"></span>添加权限</button>
    </div>
    <div id="permissionRowBar" style="display: none">
        <button type="button" lay-event="update" shiro:hasPermission="permission:update" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-edit"></span>更新</button>
        <button type="button" lay-event="deletePermission" shiro:hasPermission="permission:delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
    </div>
</div>
<!--数据表格结束-->

<!--添加和修改的弹出层开始-->
<div style="display: none; padding: 5px" id="addOrUpdateDiv">
    <form action="" method="post" class="layui-form layui-form-pane" id="dataForm" lay-filter="dataForm">
        <div class="layui-form-item">
            <label class="layui-form-label">选择菜单</label>
            <div class="layui-input-block">
                <input type="hidden" name="pid" id="pid" lay-verify="required">
                <ul id="permissionTree"  class="dtree" data-id="0"></ul>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">权限名称</label>
            <div class="layui-input-block">
                <input type="hidden" name="id">
                <input type="text" name="title" lay-verify="required" autocomplete="off" placeholder="请输入菜单名称" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">权限编码</label>
            <div class="layui-input-block">
                <input type="text" name="percode"  autocomplete="off" placeholder="请输入菜单地址" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">是否展开</label>
                <div class="layui-input-inline">
                    <input type="radio" name="open" value="1" title="展开">
                    <input type="radio" name="open" value="0" title="不展开"  checked="checked">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">是否可用</label>
                <div class="layui-input-inline">
                    <input type="radio" name="available" value="1" title="可用" checked="checked">
                    <input type="radio" name="available" value="0" title="不可用">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">排序码</label>
            <div class="layui-input-inline">
                <input type="text" id="ordernum" name="ordernum" lay-verify="required|number" autocomplete="off" placeholder="请输入大于0的排序码" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center">
                <button type="button" class="layui-btn layui-btn-normal" lay-submit="" lay-filter="doSubmit" id="doSubmit"><span class="layui-icon layui-icon-release"></span>提交</button>
                <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh"></span>重置</button>
            </div>
        </div>
    </form>
</div>
<!--添加和修改的弹出层结束-->

<!--查看弹出层的开始-->
<!--查看弹出层的结束-->

<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript">
    var tableIns;
    layui.extend({
        dtree: '/resources/layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
    }).use(['jquery','form','table','layer','dtree'],function (){
        var $=layui.jquery;
        var form=layui.form;
        var table=layui.table;
        var layer=layui.layer;
        var dtree=layui.dtree;

        // 初始化树
        var permissionTree = dtree.renderSelect({
            elem: "#permissionTree",
            dataStyle: "layuiStyle",  //使用layui风格的数据格式
            dataFormat: "list",  //配置data的风格为list
            response:{message:"msg",statusCode:0},  //修改response中返回数据的定义
            url: "/permission/loadPermissionManagerLeftTreeJson" // 使用url加载（可与data加载同时存在）
        });
        //监听树的节点点击
        dtree.on("node(permissionTree)",function (obj){
            $("#pid").val(obj.param.nodeId)
        });


        //加载表格数据
        tableIns=table.render({
            elem: '#permissionTable'
            ,url:'/permission/loadAllPermission'
            ,toolbar: '#permissionToolBar'
            ,height: 'full-250'
            ,title: '公告数据表'
            ,page: true
            ,cols: [ [
                ,{field:'id',title: 'ID',align:'center'}
                ,{field:'pid',title: '菜单ID' ,align:'center'}
                ,{field:'title',title: '权限名称',align:'center'}
                ,{field:'percode', title: '权限编码',align:'center'}
                ,{field:'available', title: '是否可用',align:'center',templet:function(d){
                        return d.available==1?'<font color="blue">可用</font>':'<font color="red">不可用</font>';
                    }}
                ,{field:'ordernum', title: '排序码',align:'center'}
                ,{fixed:'right',  title: '操作',toolbar: '#permissionRowBar',align:'center',width:'200'}
            ] ]
            ,done: function (res,curr,count) {//当删除某一页最后一条数据时刷新
                if(res.data.length==0&&curr!=1){
                    tableIns.reload({
                        page:{
                            curr:(curr-1)
                        }
                    })
                }
            }

        });

        //模糊查询
        form.on("submit(doSearch)",function (data){
            tableIns.reload({
                where:data.field, //设定异步数据接口的额外参数
                page:{
                    curr:1  //重新从第 1 页开始
                }
            })
        });

        //监听工具条事件
        table.on("toolbar(permissionTable)",function (obj){
            switch (obj.event) {
                case 'add':
                    openAddLayer();
                    break;
            }
        });

        //打开添加弹出层
        var mainIndex;
        var url;
        function openAddLayer() {
            mainIndex=layer.open({
                type: 1,
                content:$("#addOrUpdateDiv"),
                area:['800px','600px'],
                title: '添加菜单',
                success:function (){
                    $('#dataForm')[0].reset();
                    $('#pid').val("")
                    url="/permission/addPermission"
                    //初始化排序码
                    $.get("/permission/loadMaxPermissionOrderNum",function (res) {
                        $("#ordernum").val(res.value)
                    })
                }
            })

        }

        //添加和修改的提交
        form.on("submit(doSubmit)",function (data) {
            $.post(url,data.field,function (res) {
                if (res.code==200){
                    tableIns.reload();
                    // menuTree.reload();
                    // window.parent.left.permissionTree.reload();
                }
                layer.msg(res.msg);
                layer.close(mainIndex);
            })
            return false;
        })
        // $("#doSubmit").click(function () {
        //     var data=$("#dataForm").serialize();
        //     $.post(url,data,function (res) {
        //         if (res.code==200){
        //             tableIns.reload();
        //             menuTree.reload();
        //             window.parent.left.menuTree.reload();
        //         }
        //         layer.msg(res.msg);
        //         layer.close(mainIndex);
        //     })
        //
        // })

        //监听行工具条事件
        table.on("tool(permissionTable)",function (obj){
            var data=obj.data;//获得当前行数据
            switch (obj.event) {
                case 'deletePermission':
                    deleteInfo(data)
                    break;
                case 'update':
                    updateInfo(data)
                    break;

            }
        });

        //打开修改弹出层
        function updateInfo(data) {
            mainIndex=layer.open({
                type: 1,
                content:$("#addOrUpdateDiv"),
                area:['800px','600px'],
                title: '修改公告',
                success:function (){
                    $('#dataForm')[0].reset();
                    //装载数据内容
                    form.val("dataForm",data)
                    //选中之前父级的部门 nodeId=data.pid
                    dtree.dataInit("permissionTree",data.pid)
                    dtree.setSelectValue("permissionTree")
                    url="/permission/updatePermission"
                }
            })
        }

        //删除
        function deleteInfo(data) {
                    layer.confirm('你确定要删除【'+data.title+'】这个权限?', {icon: 3, title:'提示'}, function(index){
                        //do something
                        $.post("/permission/deletePermission", {id:data.id},function (res){
                            console.log(res)
                            if (res.code==200){
                                tableIns.reload();
                                menuTree.reload();
                                window.parent.left.permissionTree.reload();
                            }
                            layer.msg(res.msg);
                        })
                        layer.close(index);
                    })
        }


    });

    //给其他页面刷新当前页面数据表格的方法
    function reloadTable(id) {
        tableIns.reload({
            where: {
                id:id
            },
            page: {
                curr: 1
            }
        })
    }
</script>
</body>
</html>